<template>
  <div class="search">
    <TextSearch placeholder="请输入空间名称" :value="searchVal" @search="onSearchText" />
  </div>
  <template v-if="total > 0">
    <div class="list-wrap">
      <el-table
        ref="multipleListTable"
        class="list-table"
        :data="data"
        empty-text="暂无数据"
        row-key="_id"
        header-row-class-name="tableview-header"
        row-class-name="tableview-row"
        cell-class-name="tableview-cell"
        v-loading="loading"
        :height="550"
        style="width: 100%"
      >
        <el-table-column column-key="space" width="20" />
        <el-table-column
          v-for="field in fieldList"
          :key="(field as any)?.key"
          :label="(field as any).title"
          :column-key="(field as any).key"
          :width="(field as any).width"
          :min-width="(field as any).width || (field as any).minWidth"
          class-name="link"
        >
          <template #default="scope">
            <template v-if="(field as any).comp">
              <component :is="(field as any).comp" type="table" :value="scope.row" />
            </template>
            <template v-else>
              <span class="cell-span">{{ scope.row[(field as any).key] }}</span>
            </template>
          </template>
        </el-table-column>
        <el-table-column
          label="操作"
          :width="200"
          label-class-name="operation"
          class-name="table-options"
        >
          <template #default="scope">
            <div class="space-tool-bar">
              <ToolBar
                :data="scope.row"
                :tool-width="50"
                :tools="getTools(scope.row)"
                @click="handleClick"
              />
            </div>
          </template>
        </el-table-column>
      </el-table>
    </div>
    <div class="list-pagination">
      <el-pagination
        v-model:current-page="curPage"
        background
        @current-change="handleCurrentChange"
        layout="prev, pager, next"
        :total="props.total"
      >
      </el-pagination>
    </div>
  </template>

  <div v-else>
    <EmptyIndex :data="!searchVal ? noSpaceDataConfig : noSpaceSearchDataConfig" />
  </div>

  <SpaceModify
    v-if="showSpaceModify"
    :type="modifyType"
    :visible="showSpaceModify"
    @on-close-codify="onCloseModify"
  />
</template>
<script lang="ts" setup>
import { ref, computed } from 'vue'
import { ElMessageBox } from 'element-plus'
import 'element-plus/theme-chalk/src/message-box.scss'
import { get, map } from 'lodash-es'
import {
  noSpaceDataConfig,
  noSpaceSearchDataConfig,
  spaceListConfig
} from '@/management/config/listConfig'
import SpaceModify from './SpaceModify.vue'
import TextSearch from '@/management/pages/list/components/TextSearch.vue'
import EmptyIndex from '@/management/components/EmptyIndex.vue'
import ToolBar from './ToolBar.vue'
import { UserRole } from '@/management/utils/workSpace'
import { useWorkSpaceStore } from '@/management/stores/workSpace'

const showSpaceModify = ref(false)
const modifyType = ref('edit')
const props = defineProps({
  loading: {
    type: Boolean,
    default: false
  },
  data: {
    type: Array,
    default: () => []
  },
  total: {
    type: Number,
    default: 0
  }
})
const emit = defineEmits(['refresh'])
const workSpaceStore = useWorkSpaceStore()
const fields = ['name', 'surveyTotal', 'memberTotal', 'owner', 'createdAt']
const fieldList = computed(() => {
  return map(fields, (f) => {
    return get(spaceListConfig, f, null)
  })
})

const isAdmin = (id: string) => {
  return (
    workSpaceStore.workSpaceList.find((item: any) => item._id === id)?.currentUserRole ===
    UserRole.Admin
  )
}

const data = computed(() => {
  return props.data
})
let searchVal = ref('')
let curPage = ref(1)
const emitRefresh = (page: number, name: string) => {
  curPage.value = page
  emit('refresh', {
    curPage: page,
    name
  })
}
const handleCurrentChange = async (val: number) => {
  emitRefresh(val, searchVal.value)
}
const onSearchText = async (value: string) => {
  searchVal.value = value
  emitRefresh(1, value)
}

const getTools = (data: any) => {
  const flag = isAdmin(data._id)
  const tools = [{ key: 'modify', label: flag ? '管理' : '查看' }]
  if (flag) {
    tools.push({ key: 'delete', label: '删除' })
  }
  return tools
}

const handleModify = async (id: string) => {
  await workSpaceStore.getSpaceDetail(id)
  modifyType.value = 'edit'
  showSpaceModify.value = true
}
const handleDelete = (id: string) => {
  ElMessageBox.confirm('删除后团队内的问卷将同步被删除，是否确认本次删除？', '提示', {
    confirmButtonText: '确定',
    cancelButtonText: '取消',
    type: 'warning'
  })
    .then(async () => {
      await workSpaceStore.deleteSpace(id)
      await workSpaceStore.getSpaceList()
    })
    .catch(() => {})
}

const handleClick = (key: string, data: any) => {
  if (key === 'modify') {
    handleModify(data._id)
  } else if (key === 'delete') {
    handleDelete(data._id)
  }
}

const onCloseModify = () => {
  showSpaceModify.value = false
  workSpaceStore.getSpaceList()
}

defineExpose({ onCloseModify })
</script>
<style lang="scss" scoped>
.search {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 20px;
}
.list-pagination {
  margin-top: 20px;
  :deep(.el-pagination) {
    display: flex;
    justify-content: flex-end;
  }
}
.list-wrap {
  padding: 20px;
  background: #fff;

  .search {
    display: flex;
  }

  .list-table {
    :deep(.el-table__header) {
      .tableview-header .el-table__cell {
        .cell {
          height: 24px;
          color: #4a4c5b;
          font-size: 14px;
        }
      }
    }

    :deep(.tableview-row) {
      .tableview-cell {
        height: 42px;

        &.link {
          cursor: pointer;
        }

        .cell .cell-span {
          font-size: 14px;
        }
      }
    }
  }
}
</style>
